

日本国特許庁  
JAPAN PATENT OFFICE

2001  
05/25/01  
09/864300



11000 U.S. PTO  
05/25/01

別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office

出願年月日  
Date of Application:

2000年 5月31日

出願番号  
Application Number:

特願2000-161349

出願人  
Applicant(s):

日本電気株式会社

2001年 4月27日

特許庁長官  
Commissioner,  
Japan Patent Office

及川耕造



出証番号 出証特2001-3034935

【書類名】 特許願  
【整理番号】 49210429  
【提出日】 平成12年 5月31日  
【あて先】 特許庁長官殿  
【国際特許分類】 H04L 12/28  
【発明者】  
【住所又は居所】 東京都港区芝五丁目7番1号 日本電気株式会社内  
【氏名】 西原 基夫  
【特許出願人】  
【識別番号】 000004237  
【氏名又は名称】 日本電気株式会社  
【代理人】  
【識別番号】 100088812  
【弁理士】  
【氏名又は名称】 ▲柳▼川 信  
【手数料の表示】  
【予納台帳番号】 030982  
【納付金額】 21,000円  
【提出物件の目録】  
【物件名】 明細書 1  
【物件名】 図面 1  
【物件名】 要約書 1  
【フルーフの要否】 要

【書類名】 明細書

【発明の名称】 パイプライン処理型シェーピング装置およびその方法

【特許請求の範囲】

【請求項 1】 複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング装置であって、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情報を管理格納する格納手段と、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出手段とを含むことを特徴とするパイプライン処理型シェーピング装置。

【請求項 2】 前記算出手段は、前記パイプライン処理部へのパケットの入力に応答してこのパケットが属するフローの前記フロー情報を前記格納手段から読出す手段と、この読出し情報を参照して前記スケジューリング予定時刻を算出する手段とを有することを特徴とする請求項 1 記載のパイプライン処理型シェーピング装置。

【請求項 3】 前記パケットの前記パイプライン処理部への入力に応答して、前記格納手段のフロー情報を前記フロー毎に更新する格納情報更新手段を含むことを特徴とする請求項 1 または 2 記載のパイプライン処理型シェーピング装置。

【請求項 4】 前記格納手段は前記パイプライン処理部の処理ブロック数に等しい内部レジスタを有し、前記内部レジスタの各々は、パイプライン処理仕掛けり中の同一フローに属するパケットの前記フロー情報を格納するようにしたことを特徴とする請求項 1 ~ 3 いずれか記載のパイプライン処理型シェーピング装置。

【請求項 5】 前記フロー情報は前記パケット長の総和を含むことを特徴とする請求項 1 ~ 4 いずれか記載のパイプライン処理型シェーピング装置。

【請求項6】 前記複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング方法であって、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情報を管理格納するステップと、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出ステップとを含むことを特徴とするパイプライン処理型シェーピング方法。

【請求項7】 前記算出ステップは、前記パイプライン処理部へのパケットの入力に応答してこのパケットが属するフローの前記フロー情報を前記格納手段から読出すステップと、この読出し情報を参照して前記スケジューリング予定時刻を算出するステップとを有することを特徴とする請求項6記載のパイプライン処理型シェーピング方法。

【請求項8】 前記パケットの前記パイプライン処理部への入力に応答して、前記格納手段のフロー情報を前記フロー毎に更新するステップを含むことを特徴とする請求項6または7記載のパイプライン処理型シェーピング方法。

【請求項9】 前記格納手段は前記パイプライン処理部の処理ブロック数に等しい内部レジスタを有し、前記内部レジスタの各々に、パイプライン処理仕掛けり中の同一フローに属するパケットの前記フロー情報を格納するようにしたことを特徴とする請求項6～8いずれか記載のパイプライン処理型シェーピング方法。

【請求項10】 前記フロー情報は前記パケット長の総和を含むことを特徴とする請求項6～9いずれか記載のパイプライン処理型シェーピング方法。

【請求項11】 前記複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング方法の制御プログラムを記録した記録媒体であって、前記制御プログラムは、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情報を管理格納す

るステップと、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出ステップとを含むことを特徴とする記録媒体。

【請求項12】 前記算出ステップは、前記パイプライン処理部へのパケットの入力に応答してこのパケットが属するフローの前記フロー情報を前記格納手段から読み出すステップと、この読み出し情報を参照して前記スケジューリング予定時刻を算出するステップとを有することを特徴とする請求項11記載の記録媒体。

【請求項13】 前記パケットの前記パイプライン処理部への入力に応答して、前記格納手段のフロー情報を前記フロー毎に更新するステップを含むことを特徴とする請求項11または12記載の記録媒体。

【請求項14】 前記格納手段は前記パイプライン処理部の処理ブロック数に等しい内部レジスタを有し、前記内部レジスタの各々に、パイプライン処理仕掛けり中の同一フローに属するパケットの前記フロー情報を格納するようにしたことを特徴とする請求項11～13いずれか記載の記録媒体。

【請求項15】 前記フロー情報は前記パケット長の総和を含むことを特徴とする請求項11～14いずれか記載の記録媒体。

#### 【発明の詳細な説明】

##### 【0001】

##### 【発明の属する技術分野】

本発明はパイプライン処理型シェーピング装置およびその方法に関し、特にネットワークを構成する基幹通信装置からアクセス通信装置間へのインターフェースにおいて個々のコネクション毎にパケットもしくはセルのスケジューリング予定時刻を、パイプライン処理方式にて決定するためのスケジューリング予定時刻算出方式に関するものである。

##### 【0002】

##### 【従来の技術】

昨今のデータトラヒックの増加により、基幹通信装置とアクセス通信装置間の

インターフェースの高速化が進んでいる。アクセス装置と接続する基幹装置のインターフェースにおいては、ユーザとの契約に基づいたコネクション単位に厳密なポリシングやシェーピングを実施する必要がある。このコネクションは、ATM (Asynchronous Transfer Mode) インタフェースの場合、VC (Virtual Connection) に該当し、POS (Packet over SONET) インタフェースの時は、IP (Internet Protocol) フローに該当する。代表的なポリシング処理、シェーピング処理としては、トーカンバケット方式があげられる。

#### 【0003】

このトーカンバケット方式は、アルゴリズムの処理時間がかかるため、従来の基幹通信装置ではパイプライン処理により実現している。パイプライン処理とは、図10に示すように、トーカンバケット方式のアルゴリズムを複数の処理に分割し、個々の処理は最小パケット長Tに該当する時間で実行するものである。

#### 【0004】

##### 【発明が解決しようとする課題】

しかしながら、特にシェーピング処理において、同じコネクションに属する最小パケットが連續して入力すると以下の問題がある。すなわち、シェーピングの場合、図10で処理1にあるコネクションのパケットAが入力されて、パケットAの転送予定の時刻が決定するのは処理Nが終了する時である。従って、図11に示すように、同じコネクションに属する次のパケットBのパイプライン処理を開始するためには、パケットAに関する処理Nの終了の後になる。従って、パケットAとパケットBとの間隔が、処理1～Nまでの時間N×Tよりも短い時、個々のパケットの転送予定時刻を実時間で判定することができず、結果としてパケットAとパケットBとの間隔がN×T以上になるような、比較的ピークレート (peak-rate) の遅いコネクションにしか、シェーピング処理を行うことができない。結果として、高速インターフェースにおいては、ピークレートの高いコネクションに対するパケット転送のシェーピングを実現することが困難であった。

#### 【0005】

本発明の目的は、従来のシェーピングに関するパイプライン処理を改善することで、任意の速度のコネクションに対しても厳密なシェーピング処理を、簡易な

回路構成の追加により実現可能としたパイプライン処理型シェーピング装置およびその方法を提供することである。

## 【0006】

## 【課題を解決するための手段】

本発明によれば、複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング装置であって、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情報を管理格納する格納手段と、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出手段とを含むことを特徴とするパイプライン処理型シェーピング装置が得られる。

## 【0007】

そして、前記算出手段は、前記パイプライン処理部へのパケットの入力に応答してこのパケットが属するフローの前記フロー情報を前記格納手段から読出手段と、この読出し情報を参照して前記スケジューリング予定時刻を算出する手段とを有することを特徴とする。また、前記パケットの前記パイプライン処理部への入力に応答して、前記格納手段のフロー情報を前記フロー毎に更新する格納情報更新手段を含むことを特徴とする。更に、前記格納手段は前記パイプライン処理部の処理ブロック数に等しい内部レジスタを有し、前記内部レジスタの各々は、パイプライン処理仕掛けり中の同一フローに属するパケットの前記フロー情報を格納するようにしたことを特徴とし、そして、前記フロー情報は前記パケット長の総和を含むことを特徴とする。

## 【0008】

本発明によれば、前記複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング方法であって、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情

報を管理格納するステップと、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出ステップとを含むことを特徴とするパイプライン処理型シェーピング方法が得られる。

## 【0009】

そして、前記算出ステップは、前記パイプライン処理部へのパケットの入力に応答してこのパケットが属するフローの前記フロー情報を前記格納手段から読出すステップと、この読出し情報を参照して前記スケジューリング予定時刻を算出するステップとを有することを特徴とする。また、前記パケットの前記パイプライン処理部への入力に応答して、前記格納手段のフロー情報を前記フロー毎に更新するステップを含むことを特徴とする。更に、前記格納手段は前記パイプライン処理部の処理ブロック数に等しい内部レジスタを有し、前記内部レジスタの各々に、パイプライン処理仕掛けり中の同一フローに属するパケットの前記フロー情報を格納するようにしたことを特徴とし、前記フロー情報は前記パケット長の総和を含むことを特徴とする。

## 【0010】

本発明によれば、前記複数フローの入力パケットに関して、パイプライン処理部によりパイプライン処理を行いつつこれ等各フローのシェーピングを行ってスケジューリング予定時刻を算出するようにしたパイプライン処理型シェーピング方法の制御プログラムを記録した記録媒体であって、前記制御プログラムは、前記フロー毎に前記パイプライン処理部で仕掛けり中のフロー情報を管理格納するステップと、前記パイプライン処理部へ入力されたパケットのフローに対応する前記フロー情報を参照して、当該フローに属する全てのパケットをつないだ仮想的なパケットが入力されたものとして前記スケジューリング予定時刻を算出する算出ステップとを含むことを特徴とする記録媒体が得られる。

## 【0011】

本発明の作用を述べる。パイプライン処理と連動するキャッシュ部（格納手段）を用意し、このキャッシュ部において、パイプライン処理部で仕掛けり中のパ

ケットのフロー情報を管理し、同じフローに属するパケットがある場合は、キャッシュ部が該当のパケットを全てつなぎ合わせた仮想的なパケットを想定したパラメータをパイプライン処理部に渡し、パイプライン処理部では、この仮想的なパラメータを元にパイプライン処理を実行することにより、任意のピークレート（同じフローに属する入力パケット間隔の逆数）の速度を有するフローに対しても、またどのような高速な伝送路インターフェースにおいても、常にシェーピングによるスケジューリング予定時刻をリアルタイムで計算できるという効果が得られる。

## 【0012】

## 【発明の実施の形態】

以下に図面を参照しつつ本発明の実施例を説明する。図1を参照すると、本発明の一実施例としてのスケジューリング機能を行うシェーピング判定部の全体構成が示されている。ここで、図2を参照すると、本発明の目的とするシェーピング機能がネットワーク内で配備される位置を示している。図2に示すように、ネットワークはユーザ通信装置A, Gと、アクセス通信装置B, Fと、バックボーンである基幹網を構築する基幹通信装置C, D, Eとからなる。アクセス通信装置は、ユーザ通信装置と接続され、ユーザから来たトラヒックを束ねて基幹通信装置に送る。それらのトラヒックは、複数の基幹通信装置を経て対局のアクセス通信装置に到達し、その後ユーザ通信装置に転送される。

## 【0013】

ここで、トラヒックの種類として、IPフローもしくはATMセルを想定する。本発明で述べるシェーピング機能は、基幹通信装置からアクセス通信装置に転送するトラヒック、もしくはアクセス通信装置からユーザ通信装置に転送するトラヒックに対して行われる機能である。具体的には、個々のIPフローやATMコネクションに属するパケットに対して、IPフローやATMコネクションに規定される平均速度、ピーク速度を守るようにスケジューリングした上で伝送路に転送する機能であり、通常はパケット単位にどの時刻に転送するかを決定する処理である。

## 【0014】

図3はさらに基幹通信装置（例えば、図2のC）における本発明のシェーピング機能の適用位置を示す。図1で示される本発明の回路は図3のシェーピング判定部13に相当するものである。そもそも、基幹通信装置は、スイッチ10とIFカード11とから構成され、IFカードを介して入力してきたパケットを適正な出力ポートにスイッチングし、出力ポートに該当するIFカードではシェーピング機能を含む複数の処理を行って、伝送路にパケット転送する。

#### 【0015】

図3はシェーピング機能に関するブロックのみ示している。スイッチから転送されてくるパケットは、図3で示すIFカード11のバッファ部12にまず蓄積される。バッファ部12が個々のパケットの制御情報をシェーピング判定部13にパケット情報として渡す。シェーピング判定部13は、それらのパケット情報を元に、個々のパケット毎に転送すべきスケジューリング時刻を計算し、内部のスケジューリング予定時刻メモリに格納する。

#### 【0016】

図3で示すIFカード11のパケット読み出し部14は、常に時計15の時刻と上記スケジューリング予定時刻メモリとの内容を比較し、もし現在の時刻と同じスケジューリング予定時刻を有するパケットが登録されてあれば、そのパケットをバッファ部12から読み出し、さらに伝送路に転送するものである。

#### 【0017】

ここで、図1のブロック図に戻ると、本発明の実施例は、アクセス通信装置と接続される基幹通信装置で実現されるシェーピング処理において、複数の処理ブロックからなるパイプライン処理部20と、このパイプライン処理部内の処理ブロック1～7と協調して動作するキャッシュ部22と、パケットのスケジューリング予定時刻を格納するスケジューリング予定時刻メモリ23と、個々のパケットの属するフローに関する情報を管理する管理メモリ21と、パイプライン処理部20に付随する時計部24とを有している。

#### 【0018】

さらに、キャッシュ部22においては、内部レジスタ部26と、フロー検索部25と、レジスタ更新部27とが設けられている。内部レジスタ部26には、パ

イープライン処理部20における処理ブロック1～7の数と同じ数の内部レジスタ（分かりやすくするために、各レジスタも1～7として示している）が設けられている。

#### 【0019】

尚、図4は図1のブロック図における各ブロック間の信号内容①～⑦を説明するものであり、また図5（A）は管理メモリ21の内容を、（B）はキャッシュ部22の内部レジスタの内容を、また（C）はスケジューリング予定時刻メモリ23の内容を夫々示している。これ等に図4、5については、後述する。

#### 【0020】

パイプライン処理部20において、処理ブロック1～7が図6で示されるアルゴリズムを実行する。またパイプライン処理に付随して、図1のキャッシュ部22が図6の処理アルゴリズムに基づき動作する。

#### 【0021】

図1に示すように、キャッシュ部22は内部レジスタ部26、フロー検索部25、レジスタ更新部27から構成され、内部レジスタ部26はパイプライン処理部20の処理ブロック1～7において処理中のパケットに関するフロー情報を保持する。

#### 【0022】

管理メモリ21の構成は図5（A）で示すように、フロー識別子をアドレスとして、「トークン加算値」、「トークン加算間隔」、「トークン値」、「最新スケジューリング時刻」の情報を有する。また、キャッシュ部22の内部レジスタは図5（B）で示すように、レジスタが空きであるか否かを示す「有効ビット（valid-bit）」、「フロー識別子」、パイプライン処理部内においてフローに属するパケットの数を示す「パケット数」、当該パケットの長さの総和である「パケット長総和」からなる。なお「パケット数」は、パイプライン処理部20内に存在する（パイプライン処理仕掛け中）フローに対してのみ規定される値であり、キャッシュ部22がすべてのフローを管理する必要はない。

#### 【0023】

パイプライン処理部20の各処理ブロック1～7は、入力パケットに関して、

パイプライン的に図6の処理アルゴリズムで示される演算を行う。各処理ブロック1～7は、自分より後段の処理ブロックにおいて、自分が処理中のパケットと同じフローに属するパケットが存在しない場合、管理メモリから得た同フローの前回のパケットの最新スケジューリング時刻を元に、次に転送できるスケジューリング予定時刻を計算する。自分より後段の処理ブロックにおいて、自分が処理中のパケットと同じフローに属するパケットが存在する場合、それらのパケットと自分のパケットをつなぎ合わせた仮想的なパケットを想定し、左記パケットが転送できるスケジューリング時刻を計算する。

#### 【0024】

このように、パイプライン処理部のみで構成される従来のシェーピング方式に比べ、パイプライン処理と連動するキャッシュ部を用意し、キャッシュ部においてパイプライン処理部で仕掛けりのパケットのフロー情報を管理し、同じフローに属するパケットがある場合は、キャッシュ部が該当のパケットを全てつなぎ合わせた仮想的なパケットを想定したパラメータをパイプライン処理部に渡し、パイプライン処理部では左記の仮想的なパラメータを元にパイプライン処理を実行することにより、任意のピークレート（同じフローに属する入力パケット間隔の逆数）の速度を有するフローに対しても、またどのような高速な伝送路インターフェースにおいても、常にシェーピングによるスケジューリング予定時刻をリアルタイムで計算できる効果が得られる。

#### 【0025】

図3のシェーピング判定部13には、バッファ部12からパケット情報が転送されてくる。このパケット情報は図1のパイプライン処理部20の処理ブロック1に入力される。処理ブロック1はパケット情報内のフロー識別子を元に管理メモリ21にアクセスし、該当のパケットのフロー情報であって、パイプライン演算処理のための演算パラメータ（トークン加算値TK、トークン加算間隔L、トークン値P、最新スケジューリング時刻RT）を得る。また処理ブロック1はフロー識別子をキャッシュ部22に通知する。

#### 【0026】

キャッシュ部22は、図6で示すように、フロー識別子を元に、内部のフロー

検索部25と内部レジスタ部26の動作により、該当のフロー識別子に関する情報が内部レジスタに登録されてあるか否かを検索し、登録されている場合はその登録情報であるパケット数、パケット長総和などの情報を処理ブロック1に通知する。

【0027】

処理ブロック2は処理ブロック1から得るフロー情報とキャッシュ部22から得るフロー情報を元に、図6に規定される処理を行う。またそれに伴い、再びキャッシュ部にフロー識別子と自分のパケット長bとを送る。同時に、処理ブロック2で演算した結果を処理ブロック3に転送する。

【0028】

処理ブロック3は処理ブロック2から転送される情報を元に図6で示す処理アルゴリズムを実行し、結果を処理ブロック4に転送する。処理ブロック4は処理ブロック3から転送される情報を元に図6で示す処理アルゴリズムを実行し、結果を処理ブロック5に転送する。

【0029】

処理ブロック5は処理ブロック4から転送される情報と時計部から転送される現在時刻NTとを元に、図6で示す処理アルゴリズムを実行し、結果を処理ブロック6に転送する。処理ブロック6は処理ブロック5から転送される情報を元に図6で示す処理アルゴリズムを実行し、結果を処理ブロック7に転送する。処理ブロック7は処理ブロック6から転送される情報を元に、図6で示す処理アルゴリズムを実行し、結果を管理メモリ21、スケジューリング予定時刻メモリ23、キャッシュ部22に転送する。

【0030】

具体的には、管理メモリ21に対しては、フロー識別子をアドレスとしてアクセスし、トークン加算値、トークン加算間隔、トークン値、最新スケジューリング時刻を更新する。また、スケジューリング予定時刻メモリ23に対しては、スケジューリング予定時刻とパケット識別子を登録する。またキャッシュ部22に対しては、内部レジスタの内容を変更するために、フロー識別子、パケット長bを送る。時計部24は現在時刻NTを常に処理ブロック5に通知する。尚、図7

は図6に示したアルゴリズムに使用される変数（パラメータ）を説明する図である。

#### 【0031】

キャッシュ部22は処理ブロック2からフロー識別子、パケット長bを受け、また処理ブロック7からフロー識別子、パケット長bを受け、図6で示す処理アルゴリズムに基づき、フロー検索部25、レジスタ更新部27、内部レジスタ部26の相互処理により、内部レジスタの更新を行う。上記にあげた処理のタイミングとして、パイプライン中にフロー2に属する複数のパケットが無い場合の処理タイミングのアクセスを図8に示し、パイプライン中にフロー2に属する複数のパケットが有る場合の処理タイミングのアクセスを図9に示している。

#### 【0032】

以下、本実施例の動作につき説明する。まず、キャッシュ付きパイプライン型シェーピング回路の適用される箇所について説明する。図2で示すように、ネットワークはユーザ通信装置A、G、アクセス通信装置B、Fおよび基幹通信装置C、D、Eにより構成され、ユーザ装置A、G間の通信はアクセス通信装置B、基幹通信装置C、基幹通信装置D、基幹通信装置E、アクセス通信装置Fを介して行われる。特に、基幹通信装置→アクセス通信装置もしくはアクセス通信装置→ユーザ通信装置の箇所においては、ユーザ装置間におけるフロー単位にシェーピングの処理を行う。このシェーピング機能は、図2において、斜線で示される。

#### 【0033】

次に、基幹通信装置Cの概要を図3に示す。基幹通信装置は複数のIFカード11とスイッチ10とから構成される。伝送路からIFカードに入力されたパケットもしくはセルは、スイッチ10にて交換処理された後に、出力すべき伝送路と接続するIFカードに転送される。スイッチ13から伝送路の送信方向におけるシェーピング機能の処理は、図3に示す通り、IFカード内のバッファ部12、シェーピング判定部13、パケット読み出し制御部14、時計15の組合せにより実現される。

#### 【0034】

スイッチ10から転送されてきたパケットもしくはセルは、まずバッファ部12に蓄積される。蓄積されると同時に、バッファ部12は該当パケットに関する情報をパケット情報としてシェーピング判定部13に通知する。シェーピング判定部13は、ユーザ間通信を特定するフロー識別子を元に、個々のパケットの伝送路へのスケジューリング予定時刻を計算し、内部のスケジューリング予定時刻メモリに登録する。

## 【0035】

一方、パケット読み出し制御部14は時計部15から現在時刻の通知を受け、現在時刻に転送するはずのパケットがバッファ部12に滞留しているか否かを、シェーピング判定部13内のスケジューリング予定時刻メモリに問い合わせ、もし該当のパケットが登録されてあれば、そのパケットをバッファ部から読み出し、さらに伝送路上に転送する。以上の動作により、個々のユーザ通信装置間におけるフロー（フロー識別子で特定される）毎に、シェーピング機能を実現することができる。

## 【0036】

なお、スケジューリング予定時刻メモリ23において、同時に複数のフローのパケットが登録されている場合、パケット読み出し制御部14はこれ等複数のパケットの中から、一つのパケットのみを選択して読み出しを行う必要があるが、本発明は、この様な機能の実現に関するものではなく、シェーピング判定部13においてスケジューリング予定時刻を決定し、スケジューリング予定時刻メモリ23に登録する処理に関するものであるので、その部分のみを説明する。特に、OC-48(2.4Gbps)、OC-192(10Gbps)以上の高速回線を終端するIFカードにおいて、本発明は任意のシェーピングパラメータ（ピーク速度、平均速度等）に対して正確なスケジューリング予定時刻を決定することができる。

## 【0037】

以下、本発明における実施例につき説明する。図1で示すように、図3のシェーピング判定部13はパイプライン処理部20、管理メモリ21、キャッシュ部22、スケジューリング予定時刻メモリ23、時計部24から構成される。図3

のバッファ部12からパケット情報がパイプライン処理部に転送される。パケット情報の内容は、フロー識別子、パケット識別子、パケット長bの3つである。フロー識別子は、該当のパケットが属するユーザ装置間におけるフローを示す識別子であり、シェーピング判定部13の入力において予め付与されている。パケット識別子は、図3のバッファ部12内に滞留するパケットを特定する識別子であり、シェーピング判定部13の入力において予め付与されている。パケット長bは該当パケットの長さを示す。

#### 【0038】

パイプライン処理部20は図1で示すように、処理ブロック1～7より構成される。処理ブロック1～7には一定の処理が規定されており、各処理ブロックは前段の処理ブロックから処理結果を受け取り、自分に割り当てられている規定の処理を行った後、次の処理ブロックに結果を転送する。各ブロックの処理は、図6に記載されている。図8、9は処理ブロックのタイミングを示し、処理1～7がそれぞれ処理ブロック1～7の処理タイミングを示す。処理1～7が実施された後、パケットのスケジューリング予定時刻が決定される。

#### 【0039】

処理ブロック間で転送される情報は、図1の①に示す通り、パケット情報からのフロー識別子、パケット識別子、パケット長bと、管理メモリ21から読み出されるトークン加算値TK、トークン加算間隔L、トークン値P、最新スケジューリング時刻RTと、内部変数fbit、X、Y、Z、W、f2bit、Y2からなる。これらの情報は、図7に示されており、個々の処理ブロックが自律的に処理を行う上で必要なパラメータであり、個々の入力パケット毎に、処理ブロックを介して処理ブロック1から処理ブロック7に転送される。

#### 【0040】

管理メモリ21には、アドレスとして、処理ブロック1もしくは処理ブロック7からフロー識別子が与えられる。データとして、システム立ち上げ時に規定されるシェーピングパラメータであるトークン加算値TK、トークン加算間隔Lがある。さらに、動的に変更する値として、トークン値P、最新スケジューリング時刻RTがある。管理メモリの内容は処理ブロック1にて読み出され、処理ブロ

ック7にてPとRTのみ更新される（図1の①と⑤のアクセス）。

【0041】

スケジューリング予定時刻は連想メモリ（CAM: Content Addressable Memory）からなり、パケット識別子とそのスケジューリング予定時刻が登録されている。図3のパケット読み出し制御部14は、現在時刻と一致するスケジューリング予定時刻の登録があるか否か、スケジューリング予定時刻メモリ23にて検索し、登録がある場合にそのパケット識別子を元に、バッファ部12からパケットを読み出す。

【0042】

キャッシュ部22はフロー検索部25、レジスタ更新部27、内部レジスタ部26から構成される。キャッシュ部22はパイプライン処理部20の各処理ブロックで処理仕掛けり中のパケットのフロー情報を管理する。具体的には、各処理ブロックで処理中のパケットのフロー情報が、内部レジスタ部26の個々の内部レジスタに格納されている。パイプライン処理部内で処理中のフローの数は、個々の処理ブロックがすべて異なるフローのパケットを処理している時、最大になる。従って、内部レジスタ部の内部レジスタとして、処理ブロックの数だけ用意すれば良い。

【0043】

内部レジスタの構成は、図5（B）に示したように、本レジスタが有効であるか否かを示す有効ビット、フローを特定するフロー識別子、左記フローに属するパケットの数K（パイプライン処理部で処理仕掛けり中のパケットの中において）、左記フローに属するパケットのパケット長の総和Bとなる。

【0044】

時計部24は、現在時刻を管理し、処理ブロック5に常時、現在時刻NTを通知する。なお本時計部の時刻NTは、図3のIFカード11上の時計の時刻より、パイプライン処理の遅延に依存する時間τだけ進んでいるものとする。個々の処理ブロックの処理の流れは図6に示す通りである。

【0045】

以下に、詳細を説明する。まず、パケット情報はパイプライン処理ブ

ロック1に入力される。処理ブロック1はパケット情報内のフロー識別子を元に管理メモリ21にアクセスし、該当のパケットのフロー情報（トークン加算値TK、トークン加算間隔L、トークン値P、最新スケジューリング時刻RT）を得る（図1の②のアクセス）。処理ブロック1はさらにフロー識別子をキャッシュ部22に通知する。キャッシュ部22のフロー検索部25は図6で示すように左記フロー識別子を元に、内部レジスタ部26において、該当のフロー識別子に関する情報が内部レジスタに登録されてあるか否かを検索し、登録されている場合は、登録情報であるパケット数K、パケット長総和Bを処理ブロック1に通知する（図1の③のアクセス）。

#### 【0046】

処理ブロック2は処理ブロック1およびキャッシュ部22からパケットの属するフローの情報を受け取り、処理ブロック2～7において、自分の有するパケットと同じフローに属するパケットがあるか否かで異なる処理を行う。自分の有するパケットと同じフローに属するパケットがない場合は、処理ブロック1にて管理メモリ21から読み出された情報のみを元にしてシェーピングのスケジューリング予定時刻判定を行う。

#### 【0047】

自分の有するパケットと同じフローに属するパケットがある場合は、同様にシェーピングのスケジューリング予定時刻判定を行うことができない。というのは、管理メモリ21にはパイプライン処理部20で処理中のフローに関する結果が反映されていないからである。そこで、後段の処理ブロック3～7に含まれる同じフローのパケット情報も含めた上で、スケジューリング予定時刻を決定する。具体的には、現状のトークン値P、最新スケジューリング時間RT、パケット長＝「処理ブロック2で処理中のパケット長b」＋「処理ブロック3～7に含まれる同じフローのパケット長の総和B」を元にスケジューリング予定時刻を決定する。

#### 【0048】

つまり、仮想的にパケット長bではなく、パケット長＝b+Bの大きなパケットが入力したものとして、スケジューリング予定時刻の決定を行う。これにより

、パイプライン処理部内に同じフローに属するパケットがある場合でも、常に正しいスケジューリング予定時刻を決定することができる。

【0049】

また、IFカード11の伝送路速度が上がり図8、9のパケット情報転送時間 $t$ が短くなる場合には、さらに細かい処理ブロック1～N ( $N > 8$ ) に分割することにより、個々の処理ブロックの処理時間 $t$ を短くすることができる。結果として、インターフェースの高速化に関わらずスケジューリング予定時刻を正しく判定することができる。

【0050】

処理ブロック2は、キャッシュ部から得るパケット数Kが0の時、処理ブロック2のパケットと同一のフローに属するパケットが、後段の処理ブロックに存在しないことを認識する。従って、処理ブロック1にて管理メモリから得た最新スケジューリング予定時刻RTの次に転送できる時刻を決定すれば良い。

【0051】

まず、現状のトークン値がパケット転送を行うのに足りているか否かの判定を行う。最新のトークン値は管理メモリから得られるPであり、処理中のパケットの長さはbなので、 $X = P - b$ の計算を行い、 $X > 0$ ならばトークン値が足りていているので、RTの次の時間にパケットを転送することができ、 $X \leq 0$ ならば、トークンがたまって $X > 0$ となるまでスケジューリング予定時刻を遅らせる。また $X > 0$ ならばRTの次の時間に即時にパケット転送できることを後段の処理ブロックに通知するために、fbit = 1とし、 $X \leq 0$ の時はfbit = 0とする。

【0052】

また、キャッシュ部から得るパケット数K > 0の時は、後段の処理ブロックに同一のフロー識別子を有するパケットが自分以外にK個存在するとして認識する。K個の転送予定時刻はパイプライン処理が終了していないので、決定していない。従って、管理メモリの最新スケジューリング予定時刻RTは、同じフロー識別子を有する直前のパケットのスケジューリング予定時刻ではなく、K個前のパケットのスケジューリング予定時刻である。そこで、K個前のパケットのスケジューリング予定時刻から始まって、K + 1個目のパケットを転送する時刻を決定

すれば良い。

【0053】

まず、必要なトークン値を確認するために、 $X = P - b$  の代わりに  $X = P - (B + b)$  の計算を行う。Xは該当のパケットを転送するために足りないトークン値を示すので、 $X > 0$  ならばトークン値が足りており、RTの次の時間にパケットを転送することができる。もし  $X \leq 0$  ならば、トークンがたまって  $X > 0$  となるまで、スケジューリング予定時刻を遅らせなければならない。 $X > 0$  ならば RTの次の時間に即時にパケット転送できることを後段の処理ブロックに通知するために、fbit = 1 とする。 $X \leq 0$  の時は、fbit = 0 とする。

【0054】

処理ブロック2が処理しているパケットにより、パイプライン処理部内のフローの情報が変わるので、キャッシュ部が内部レジスタの変更を行わなければならない。そこで、処理ブロック2は処理中のパケットのフロー識別子、パケット長bをキャッシュ部に転送する。

【0055】

処理ブロック3は処理ブロック2より通知されるfbitおよびXを元にパケットのスケジューリング予定時刻と、このスケジューリング予定時刻における新たなトークン値を決定するために、まず何回トークンTKを足せば  $X > 0$  となるかの計算を行う。この加算され得る回数をYとする。

【0056】

処理ブロック3は、fbit = 0 の時  $X \leq 0$  なので、 $X > 0$  になるまでに何回トークン量TKの加算が必要か知るために、 $Y = (|X| + 1) \div TK$  の計算を行う（ $|X|$  はXの絶対値を示す）。またfbit = 1 の時、既にスケジューリング予定時刻は RTの次の時間 RT + 1 であることが決定しているので、 $Y = (RT + 1 - RT) \div TK = 1 \div TK$  の計算を行う。

【0057】

上記のYは該当のフロー識別子のパケットに関し、 $X < 0$  の時は最新スケジューリング予定時刻 RT に Y 回のトークン加算間隔時間 L を経た時刻にトークン値 P が 0 以上になることを示している。

## 【0058】

処理ブロック4はYを元に該当のパケットのスケジューリング予定時刻とその時のトークン値を決定する。スケジューリング予定時刻はYの定義より $Z = Y \times L + R T$ より得られる。また、トークン値は、 $fbit = 1$ の時（ $X > 0$ の時と同義）、 $W = |X| + 1$ となり（ $W = Y \times TK + X$ と同義）、 $fbit = 0$ の時（ $X \leq 0$ と同義）、 $W = 1$ となる（ $W = Y \times TK + X$ と同義）。

## 【0059】

処理ブロック5は、処理ブロック4で得られたスケジューリング予定時刻Zとトークン値Wの補正を行う。また処理ブロック5は時計部から現在時刻NTを得る。もしZが現在の時刻NTより後の時間の場合は、ZとWの補正の必要はない。後段の処理ブロックに補正処理の必要がないことを通知するために、 $f2bit = 0$ とする。

## 【0060】

しかしながら、 $NT > Z$ の時、スケジューリング予定時刻は既に過去の時刻であるので、スケジューリング時間ZはNTに補正し、合わせてWも補正する必要がある。そこで、新たに $Y2 = (NT - Z) \div TK$ の演算を行う。さらに、後段の処理ブロックに補正処理の必要を通知するために、 $f2bit = 1$ とする。 $NT \leq Z$ の時は $f2bit = 0$ とする。

## 【0061】

処理ブロック6は、 $f2bit = 1$ の時に、処理ブロック5に引き続いで補正処理を進める。新たなスケジューリング予定時刻として、 $Z = NT$ とする。またトークン値として、 $W = W + NT - Z$ とする。 $f2bit = 0$ の時は何も行わない。

## 【0062】

処理ブロック7は処理ブロック6で得られた結果を元に各テーブルの更新を行う。まず、Zとパケット識別子をスケジューリング予定時刻メモリに登録する。またフロー識別子をアドレスとして、管理メモリにアクセスし、新たにTK、L、W、Zの値を書き込む。

## 【0063】

なお、図8、9で示すように、管理メモリの読み出しフェース（R）・書き込

みフェーズ (W) が重ならないように、各処理時間の前半と後半とで夫々のタイミング規定をすることにより、管理メモリにアクセスする処理ブロック 1 と処理ブロック 7 とがアクセス競合を引き起こすことはない。また、処理ブロック 7 にて処理中のパケットはパイプライン処理部から読み出されるので、キャッシュ部の内部レジスタの情報を更新する必要がある。そこで、フロー識別子、パケット長 b をキャッシュ部に通知する。

## 【0064】

キャッシュ部はパイプライン処理部内の処理ブロックと同期してパイプライン処理部内で処理中のパケットの属するフローに関する管理を行う。キャッシュ部は内部レジスタ部とフロー検索部と内部レジスタ更新部から構成される。内部レジスタ部には、複数の内部レジスタが存在し、この内部レジスタの数はパイプライン処理部における処理ブロックの数と同じである。

## 【0065】

内部レジスタには、パイプライン処理部内の処理ブロックで処理中のパケットに関するフローの情報のみ格納されている。内部レジスタは、図5 (B) に示すように、4つのフィールドから構成される。第1に有効ビットである。有効ビットは内部レジスタが使用中か否かを示し、有効ビットが 0 n の時、あるフロー識別子が登録されており、有効ビットが 0 f f の時は何も登録されておらず、空き (empty) であることを示す。

## 【0066】

第2にフロー識別子フィールドである。フロー識別子フィールドには、パケットに付随して転送されるフロー識別子が登録される。第3にパケット数 K である。パケット数 K は、第2のフロー識別子に属するパケットがパイプライン処理部に何個存在するかを示す。第4にパケット長の総和 B である。パケット長の総和 B はパイプライン処理部内に存在するフロー識別子のフローのすべてのパケットの長さの総和である。

## 【0067】

フロー検索部 25 は内部レジスタの中で特定のフロー識別子に関するレジスタを探索する。内部レジスタ更新部 27 は個々の内部レジスタの更新を行う。また

、各レジスタ内に保持されるパケット数フィールドに対する演算（ $K = K + 1$  の加算、 $K = K - 1$  の減算）、パケット長総和に対する演算（ $B = B + b$ 、 $B = B - b$ ）等を行う。

#### 【0068】

まず、キャッシュ部が処理ブロック1からフロー識別子を受け取ると、フロー検索部25が内部レジスタ部26の内部レジスタにおいて、フロー識別子と一致し、かつ有効ビットが $o_n$ となるエントリの検索を行う。一致するエントリが検索できた場合は、該当エントリの内部レジスタの内容（パケット数K、パケット長の総和B）を読み出し、パケット数K、パケット長の総和Bを処理ブロック2に返す。一致するエントリが見つからない場合は、パケット数K=0として処理ブロック2に返す。

#### 【0069】

またキャッシュ部22は処理ブロック2からフロー識別子、パケット長bを受信し、左記情報に基づくパケット情報の追加処理を行う。また、処理ブロック7からフロー識別子、パケット長bを受信し、この情報に基づくパケット情報の削除処理を行う。処理ブロック2からのフロー識別子をflowinfo1、パケット長をpktlen1と規定し、処理ブロック7からのフロー識別子をflowinfo2、パケット長をpktlen2と規定すると、以下の規則に元づいて行われる。

#### 【0070】

Flowinfo1=flowinfo2の時、内部レジスタ部には既にflowinfo1のフロー情報が存在しており、処理ブロック2からの通知によるパケット追加と処理ブロック7からのパケット削除により、内部レジスタのパケット数Kは変わらない。パケット長の総和Bは、処理ブロック2からのパケット長追加と処理ブロック7からのパケット長削除を反映させる必要がある。

#### 【0071】

まず、フロー検索部は、内部レジスタ部の内部レジスタにおいて、flowinfo1のフロー識別子と一致し、かつ有効ビットが $o_n$ となるエントリの検索を行う。このエントリに対して、パケット長の総和 $B = B + pktlen1 - pktlen2$ の計算を行い、該当エントリのレジスタ内容を更新する。

## 【0072】

Flowinfo1 ≠ flowinfo2 の時、処理ブロック 2 からの通知によるフロー情報の追加処理と、処理ブロック 7 からの通知によるフロー情報の削除処理を同時に行う。まず処理ブロック 2 からの通知によるフロー情報の追加処理について説明する。フロー検索部は、flowinfo1 とフロー識別子が一致し、かつ有効ビットが○n となるエントリを検索する。そして、レジスタ更新部は、このエントリに対して、パケット数  $K = K + 1$ 、パケット長の総和  $B = B + \text{pktlen1}$  の演算を行い、レジスタ内容の変更を行う。

## 【0073】

もし、flowinfo1 とフロー識別子が一致し、かつ有効ビットが○n となるエントリが無い場合は、flowinfo1、pktlen1 のフロー情報を新たに登録するために、有効ビットが○ff となる空きエントリを検索する。このエントリに、フロー識別子、パケット数  $K = 1$ 、パケット長の総和  $B = \text{pktlen1}$  を登録する。

## 【0074】

Flowinfo1 ≠ flowinfo2 の時、処理ブロック 2 からの通知によるフロー情報の追加処理と、処理ブロック 7 からの通知によるフロー情報の削除処理を同時に行う。まず処理ブロック 2 からの通知によるフロー情報の追加処理について説明する。

## 【0075】

フロー検索部 2 2 は、flowinfo1 とフロー識別子が一致しかつ有効ビット○n となるエントリを検索する。そして、レジスタ更新部は、このエントリに対して、パケット数  $K = K + 1$ 、パケット長の総和  $B = B + \text{pktlen1}$  の演算を行い、レジスタ内容の変更を行う。もし、flowinfo1 とフロー識別子が一致し、かつ有効ビット○n となるエントリが無い場合は、flowinfo1、pktlen1 のフロー情報を新たに登録するために、有効ビット○ff となる空きエントリを検索する。このエントリに、フロー識別子、パケット数  $K = 1$ 、パケット長の総和  $B = \text{pktlen1}$  を登録する。

## 【0076】

次に、処理ブロック 7 からの通知によるフロー情報の削除処理について説明す

る。フロー検索部は、flowinfo2 とフロー識別子が一致しかつ有効ビット  $o.n$  となるエントリを検索する。そして、レジスタ更新部は、このエントリに対して、パケット数  $K = K - 1$ 、パケット長の総和  $B = B - \text{pktlen2}$  の演算を行い、レジスタ内容の変更を行う。ただし、元々のパケット数  $K = 1$  の時は、パイプライン処理部から flowinfo2 のフローに属するパケットが無くなることを意味しているので、単に有効ビットを  $o.f.f$  とすれば良い。処理ブロック 7 からの通知による処理は、既に内部レジスタに存在するフロー情報の更新であるため、フロー検索部の処理でエントリが無いケースを想定する必要はない。

#### 【0077】

以上の処理は、限られたフロー数（最大でもパイプライン処理部内の処理ブロックの数）の内部レジスタに関する登録、更新処理であり、キャッシュ部全体を組合せ回路等により最適化して設計することにより、実時間で簡易に実現することが可能である。以上の処理ブロック、キャッシュ部の処理のタイミングを図 8, 9 に示す。

#### 【0078】

図 8 は、パイプライン中に同一のフローに属するパケットが 1 つしかない場合の処理タイミングである。パケット情報として、フロー 1、フロー 2、フロー 3、フロー 4、フロー 5、フロー 6、フロー 7 が連続しているものの、パイプラインの処理段数は処理 1 ~ 処理 7 の 7 段しかないため、個々の処理ブロックはそれぞれ異なるフローのパケットを処理することになる。図 8 で示すように、管理メモリに関しては、読み出しフェーズ（1）と書き込みフェーズ（4）が処理周期の前半・後半に明確に分離されているため、アクセス競合は発生しない。

#### 【0079】

同様に、スケジューリング予定時刻メモリも処理周期の前半（6）でのみ規定されているのでアクセス競合は発生しない。内部レジスタの場合、読み出しフェーズ（処理周期の前半（2））と書き込みフェーズ（処理周期の後半（3）または（5））は明確に分離されている。しかし、書き込みフェーズにおいて、処理ブロック 2 と処理ブロック 7 とがそれぞれ同時に書き込みのアクセスを行うため、アクセス競合が発生する。この場合でも、既に述べたように内部レジスタの数

はパイプライン処理部内の処理ブロック数（図中では7個）に限られているので、内部レジスタのアクセス処理を組合せ回路等で最適化して構成することができ、通常のメモリと異なり処理可能となる。

#### 【0080】

なお、図8はフロー2パケットの入力に関するアクセスのみ記載しており、実際には個々のフローのパケットに対して、処理ブロック1～処理ブロック7が常に動作しているため、毎処理周期で常に管理メモリ、内部レジスタ、スケジューリング予定時刻メモリへのアクセスが発生している。

#### 【0081】

図9は、図8の例とは異なってパイプライン中に同一のフローに属するパケットが複数ある場合の処理タイミングの例である。図9では、斜線で示した2個のフロー2パケットが同時にパイプライン中に存在する。図9の(5)で示すように、特に内部レジスタの書き込み処理にて、フロー2に関して、処理ブロック2と処理ブロック7とから同時に更新するアクセスが発生している。この処理に関しても、既に述べたように、処理ブロック2からのフロー識別子(flowinfo1)と処理ブロック7からのフロー識別子(flowinfo2)が一致した場合に、それぞれのパケット長b（処理ブロック2の場合pktlen1、処理ブロック7の場合pktlen2）を元にした書き込みルールを規定することにより、両者の要求を満足した内部レジスタの更新が可能である。

#### 【0082】

個々の処理ブロックの機能は、パイプライン処理部に入力するパケットの速度、パイプライン処理部におけるアルゴリズムの困難さに応じて決定される。また実施例では処理ブロック1～7で行っているが、必要に応じて処理ブロック数を増やし、処理ブロック1～N（N≥8）としても良い。パイプライン処理部に入力するパケットの速度が速いほど、またパイプライン処理部におけるアルゴリズムが困難であるほど、処理ブロックの数を増やす必要がある。また、内部レジスタ部における内部レジスタの数は処理ブロックの数と一致するので、内部レジスタの数も処理ブロックの数と同様に増える。

#### 【0083】

上記実施例では、内部レジスタ部の構成として、複数の内部レジスタが独立に存在し、フロー識別子を元に内部レジスタを検索したり更新できる機能を規定している。内部レジスタ部の左記機能をすべて連想メモリを使用して実現しても良い。上記実施例では、シェーピング処理に基づいて記述している。しかしながら、本発明の特徴は、上述したように、イープライン処理部に付随してキャッシュ部を設け、キャッシュ部内にはパイプライン処理部で仕掛けり中のパケットのフロー情報を管理し、パイプライン処理部ではキャッシュ部のフロー情報に基づき、仮想的なスケジューリングパラメータで処理を行うという点にある。つまり、シェーピング処理のアルゴリズムに依存せずに、さまざまな複雑なアルゴリズムに適応できる。例えば、シェーピング処理ではなく、パケット廃棄に関するトークンパケットベースのポリシング処理も、同様に実現可能である。

## 【0084】

## 【発明の効果】

以上述べたように、パケットのフロー単位にシェーピングを行う技術に関して、パケット単位に処理が移動するパイプライン処理部に付随して連動するキャッシュ部を設け、このキャッシュ部においてパイプライン処理部内で処理中のパケットのフロー情報を管理する内部レジスタを有し、個々のパケットのスケジューリング時間の計算において、キャッシュ部からの通知により同一のフローに属するパケットが存在しない時は従来方法と同様に、同フローに属する1個前のパケットのスケジューリング予定時刻とトークン値を元に、次のパケットのスケジューリング予定時刻を計算し、キャッシュ部からの通知によりパイプライン処理部に同一のフローに属するパケットが存在する時は、それらのすべてのパケットをつなげた大パケットが仮想的に入力したものと見なして、次のパケットのスケジューリング予定時刻を計算することにより、同じフローに属するパケットが連續して入力しても、常に正しいスケジューリング時間を計算できるという効果がある。

## 【0085】

また、本発明によれば、パイプライン処理部のパイプラインの段数（図1におけるパイプライン処理部内の処理ブロックの数）がいくつであっても実現可能で

るので、伝送路の高速化にあわせてパイプラインの段数を増加させることで、将来の伝送路速度の高速化に際しても、任意のスケジューリングパラメータによるスケジューリング判定処理を実現することができる。

【0086】

更にはまた、本発明による技術を用いずに高速な伝送路におけるシェーピング処理を実現する場合は、個々の高速なスケジューリング判定回路をフロー数だけ用意せざる得ないが、一般にフロー数は数k～数10kにわたるため、極めて大規模な回路が必要であったのに比べ、本発明では、フロー単位に管理情報をメモリから読み出して行うパイプライン処理と、パイプライン処理の段数のみで規定されるキャッシュ部で実現されるため、小規模な回路で実現でき、結果として、ハードウェアコストの削減、消費電力の削減を実現することができるという効果がある。

【図面の簡単な説明】

【図1】

本発明の実施例のブロック図である。

【図2】

本発明によるシェーピング機能のシステム上の配置位置を示す図である。

【図3】

基幹装置の構成とシェーピング判定部の位置関係を示す図である。

【図4】

図1のブロック間信号の内容を示す図である。

【図5】

(A) は管理メモリのフィールド構成を示し、(B) は内部レジスタのフィールド構成を示し、(C) はスケジューリング予定時刻メモリのフィールド構成を示す図である。

【図6】

パイプライン処理部およびキャッシュ部の処理フローである。

【図7】

図6の処理フローにおける変数(パラメータ)を説明する図である。

【図8】

本発明の実施例の動作を示すタイミングの一例である。

【図9】

本発明の実施例の動作を示すタイミングの他の例である。

【図10】

パイプライン処理を説明する図である。

【図11】

シェーピングに関するパイプライン処理の問題点を説明する図である。

【符号の説明】

- 1 0 スイッチ部
- 1 2 バッファ部
- 1 3 シェーピング判定部
- 1 4 パケット読み出し制御部
- 1 5 時計
- 2 0 パイプライン処理部
- 2 1 管理メモリ
- 2 2 キャッシュ部
- 2 3 スケジューリング予定時刻メモリ
- 2 4 時計部
- 2 5 フロー検索部
- 2 6 内部レジスタ部
- 2 7 レジスタ更新部

### 【書類名】

図面

【図1】



【図2】

## ネットワークモデル



【図3】



【図4】

ブロック間信号の内容:

- ① パイプライン処理部内の処理ブロック間の信号  
フロー識別子、パケット識別子、TK、L、P、RT、内部変換としてf bit、X、Y、Z、W、f 2bit、Y2、
- ② 管理メモリのアドレスとしてフロー識別子、データとしてTK、L、P、RT、
- ③ 処理ブロック1→キャッシュ部にフロー識別子、キャッシュ部→処理ブロック1にK、B、
- ④ 処理ブロック2→キャッシュ部にフロー識別子、パケット長b、
- ⑤ 管理メモリのアドレスとしてP=W、データとしてトークン加算値TK、トークン加算間隔L、  
新たなトークン値としてRT=Z、スケジューリング予定時刻としてRT=Z、
- ⑥ スケジューリング予定時刻Z、パケット識別子、
- ⑦ 処理ブロック7→キャッシュ部にフロー識別子、パケット長b、
- ⑧ 現在時刻NT

【図5】

(A)



(B)



(C)



【図6】



【図7】

| 変数の説明:          |                                                                                                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ① 管理メモリからの読み出し  | TK=トークン加算値<br>L=トークン加算間隔<br>P=トークン値<br>RT=最新スケジューリング時間                                                                                                                    |
| ② キャッシュ部からの読み出し | K=パケット数<br>B=パケット長総和<br>valid-bit=レジスタ有効無効                                                                                                                                |
| ③ 内部変数          | f bit=トークンが足りているか否かの識別<br>X=足りないトークン量<br>Y=必要なトークン加算間隔の数<br>Z=新たなスケジューリング予定時刻<br>W=新たなトークン値<br>f 2bit=新たなスケジューリング予定時刻<br>Zと現時刻の前後関係を示す。<br>Y2=Zと現時刻までに加算されるトークン<br>加算の回数。 |
| ④ その他           | b=処理パケットのパケット長<br>NT=現在時刻                                                                                                                                                 |

【図8】



【図9】



【図10】



【図11】



【書類名】 要約書

【要約】

【課題】 任意の速度のコネクションに対しても厳密なシェーピング処理を、簡易な回路構成の追加により実現可能としたパイプライン処理型シェーピング方式を得る。

【解決手段】 パイプライン処理部20の処理と連動するキャッシング部22を用意し、このキャッシング部22において、パイプライン処理部20で仕掛け中のパケットのフロー情報を管理し、同じフローに属するパケットがある場合は、キャッシング部22が該当のパケットを全てつなぎ合わせた仮想的なパケットを想定したパラメータをパイプライン処理部20に渡し、パイプライン処理部20ではこの仮想的なパラメータを元にパイプライン処理を実行することにより、任意のピーカレート（同じフローに属する入力パケット間隔の逆数）の速度を有するフローに対しても、またどのような高速な伝送路インターフェースにおいても、常にシェーピングによるスケジューリング予定時刻をリアルタイムで計算できる。

【選択図】 図1

出願人履歴情報

識別番号 [000004237]

1. 変更年月日 1990年 8月29日  
[変更理由] 新規登録  
住 所 東京都港区芝五丁目7番1号  
氏 名 日本電気株式会社